<script>
export default{
    name:'SvgIcon',
    props:{
        icon:{
            type:String,
            required:true
        },
        className:{
            type:String,
            default:''
        },
        size:{
            type:String,
            default:'16px'
        }
    },
    computed:{
        iconName(){
            return `#icon-${this.icon}`
        },
        svgClass(){
            if(this.className){
                return 'svg-icon ' + this.className
            }else{
                return 'svg-icon'
            }
        }
    }
}
</script>

<template>
    <svg :class="svgClass" aria-hidden="true" v-on="$listeners" :style="{width:size,height:size}">
        <use :xlink:href="iconName"/>
    </svg>
</template>

<style scoped>
    .svg-icon{
        width:1em;
        height:1em;
        vertical-align: -0.15rem;
        fill:currentColor;
        overflow:hidden;
    }
</style>